home *** CD-ROM | disk | FTP | other *** search
/ Personal Computer World 2009 February / PCWFEB09.iso / Software / Linux / Kubuntu 8.10 / kubuntu-8.10-desktop-i386.iso / casper / filesystem.squashfs / usr / share / pyshared / PIL / SgiImagePlugin.py < prev    next >
Text File  |  2006-12-03  |  2KB  |  92 lines

  1. #
  2. # The Python Imaging Library.
  3. # $Id: SgiImagePlugin.py 2134 2004-10-06 08:55:20Z fredrik $
  4. #
  5. # SGI image file handling
  6. #
  7. # See "The SGI Image File Format (Draft version 0.97)", Paul Haeberli.
  8. # <ftp://ftp.sgi.com/graphics/SGIIMAGESPEC>
  9. #
  10. # History:
  11. # 1995-09-10 fl     Created
  12. #
  13. # Copyright (c) Secret Labs AB 1997.
  14. # Copyright (c) Fredrik Lundh 1995.
  15. #
  16. # See the README file for information on usage and redistribution.
  17. #
  18.  
  19.  
  20. __version__ = "0.1"
  21.  
  22.  
  23. import string
  24. import Image, ImageFile
  25.  
  26.  
  27. def i16(c):
  28.     return ord(c[1]) + (ord(c[0])<<8)
  29.  
  30. def i32(c):
  31.     return ord(c[3]) + (ord(c[2])<<8) + (ord(c[1])<<16) + (ord(c[0])<<24)
  32.  
  33.  
  34. def _accept(prefix):
  35.     return i16(prefix) == 474
  36.  
  37. ##
  38. # Image plugin for SGI images.
  39.  
  40. class SgiImageFile(ImageFile.ImageFile):
  41.  
  42.     format = "SGI"
  43.     format_description = "SGI Image File Format"
  44.  
  45.     def _open(self):
  46.  
  47.         # HEAD
  48.         s = self.fp.read(512)
  49.         if i16(s) != 474:
  50.             raise SyntaxError, "not an SGI image file"
  51.  
  52.         # relevant header entries
  53.         compression = ord(s[2])
  54.  
  55.         # bytes, dimension, zsize
  56.         layout = ord(s[3]), i16(s[4:]), i16(s[10:])
  57.  
  58.         # determine mode from bytes/zsize
  59.         if layout == (1, 2, 1):
  60.             self.mode = "L"
  61.         elif layout == (1, 3, 3):
  62.             self.mode = "RGB"
  63.         else:
  64.             raise SyntaxError, "unsupported SGI image mode"
  65.  
  66.         # size
  67.         self.size = i16(s[6:]), i16(s[8:])
  68.  
  69.         # decoder info
  70.         if compression == 0:
  71.             if self.mode == "RGB":
  72.                 # RGB images are band interleaved
  73.                 size = self.size[0]*self.size[1]
  74.                 self.tile = [("raw", (0,0)+self.size, 512, ("R",0,1)),
  75.                              ("raw", (0,0)+self.size, 512+size, ("G",0,1)),
  76.                              ("raw", (0,0)+self.size, 512+2*size, ("B",0,1))]
  77.             else:
  78.                 self.tile = [("raw", (0,0)+self.size, 512, (self.mode, 0, 1))]
  79.         if compression == 1:
  80.             self.tile = [("sgi_rle", (0,0)+self.size, 512, (self.mode, 0, 1))]
  81.  
  82. #
  83. # registry
  84.  
  85. Image.register_open("SGI", SgiImageFile, _accept)
  86.  
  87. Image.register_extension("SGI", ".bw")
  88. Image.register_extension("SGI", ".rgb")
  89. Image.register_extension("SGI", ".rgba")
  90.  
  91. Image.register_extension("SGI", ".sgi") # really?
  92.